<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="../assets/css/base.css">
</head>
<body>
    <div id="app">
        <h3>VUE2</h3>
        <pre v-pre class="note">
        vm.$forceUpdate()：迫使 Vue 实例重新渲染。
        </pre>
        <p>user:{{ user }}</p>
        <input type="button" value="添加新属性age" @click="addAge()">
    </div>
    <script type="module">
        import Vue from "../assets/vue2/vue.esm.browser.js";
        new Vue({
            el:"#app",
            data() {
                return {
                    user:{
                        name:"tom"
                    }
                }
            },
            methods: {
                addAge() {
                    // vue2 为新增属性完成手动响应式定义
                    // this.$set(this.user,"age",33)

                    // 增加不具有响应式的普通属性
                    this.user.age = 33;
                    // 手动触发vue的DOM渲染
                    this.$forceUpdate();
                }
            },
        })
    </script>
</body>
</html>